package com.kdtech.analyse.outside;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;

import com.kdtech.crawler.CrawlHTML;

import com.kdtech.crawler.at.UrlArgumentTop;
import com.kdtech.entity.crawler.UrlMeta;
import com.kdtech.entity.data.NewsMeta;
import com.kdtech.analyse.AnalyseNews;
import com.kdtech.utils.DateUtils;
import com.kdtech.utils.HtmlCleaner;
import com.kdtech.utils.RegexUtils;
import com.kdtech.utils.StringUtils;

/**
 * @name 英国独立报
 * @link http://www.independent.co.uk/
 * @author dhy
 */
public class IndependentOutsideAnalyse implements AnalyseNews {

	private static final String[] regex={
		"http://www.independent.co.uk/[a-z\\-]+/[a-z\\-]+/.*-.*",
		"http://www.independent.co.uk/[a-z\\-]+/[a-z\\-]+/[a-z\\-]*/.*-.*",
	};

	
	public boolean isDetailPage(String url) {
		return RegexUtils.matchAnyIgnoreCase(url, regex);
	}

	
	public NewsMeta parserHtml(UrlMeta urlMeta) {
		NewsMeta news=new NewsMeta();
		if (urlMeta.getHtml() == null) {
		}
		String htmltxt=urlMeta.getHtml();
		String url=urlMeta.getUrl();

		news.setUrl(url);
		String title=null;
		String content=null;
		String author=null;
		Long date=null;
		Document doc=Jsoup.parse(htmltxt);
		
		title =doc.select("h1[itemprop=headline]").text();
		
		String dateStr = doc.select("time").attr("data-microtimes");
		if(StringUtils.isNotBlank(dateStr)){
			dateStr = StringUtils.substringBetween(dateStr, "published\":\"", "\",\"");
			try{
				date = Long.parseLong(dateStr);
			}catch (Exception e) {
			}
		}
		
		if(date==null)
			date =DateUtils.matchDate(doc.select("time").attr("data-microtimes"));
		
		content=HtmlCleaner.getContentHtml(url,doc.select("div.main-content-column"));
		
		news.setTitle(StringUtils.trimSpace(title));
		news.setContent(content);
		news.setAuthor(author);
		news.setDate(date);

		return news;
	}

	

	

	
}
